// pages/login/login.js
import request from '../../utils/request';
Page({

  /**
   * 页面的初始数据
   */
  data: {
    phone: '',//手机号
    password: ''//密码
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {

  },

  handleInput(event) {
    let type = event.currentTarget.id;//这里不牵扯事件委派，完全等价于用event.target
    this.setData({
      //id值于data中的key值相同，直接通过id值修改data对象
      [type]: event.detail.value,
    })
  },
  async login() {
    let {phone, password} = this.data;

    //前端验证部分

    if(!phone) {//如果手机号为空
      wx.showToast({
        title: '手机号不能为空',
        icon: 'none'
      })
      return;
    }
    let phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/;
    if(!phoneReg.test(phone)) {
      wx.showToast({
        title: '手机号格式错误',
        icon: 'none',
      });
      return;
    }
    //密码只判断不为空
    if(!password) {
      wx.showToast({
        title: '密码不能为空',
        icon: 'none',
      });
      return;
    }

    //后端验证部分
    let result = await request('/login/cellphone', {phone, password});
    if(result.code === 200) {
      wx.showToast({
        title: '登陆成功',
      })
      wx.setStorageSync('userInfo', JSON.stringify(result.profile));
      wx.setStorage({
        key: 'cookie',
        data: result.cookie
      })
      //wx.switchTab({
      wx.reLaunch({
        url: '/pages/personal/personal'
      })
    }else if(result.code === 400) {
      wx.showToast({
        title: '手机号错误',
        icon: 'none',
      })
    }else if(result.code === 502) {
      wx.showToast({
        title: '密码错误',
        icon: 'none'
      })
    }else {
      wx.showToast({
        title: '登陆失败，请重新登录',
        icon: 'none',
      })
    }

  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})